/**
 * Created with IDEA
 * author:ju bai
 * Date:2021/7/9
 * Time:17:04
 **/
public class InsertSort {
    /**
     * 插入排序
     * 时间复杂度：
     * 最坏情况下：当数据是无序的情况下：O(n^2)
     * 最好情况下：当数据有序的时候，可以达到O(n)
     * 所以：结论：越有序越快。
     * 题目：当前有一组待排序序列，但是这组待排序序列大部分是有序的。
     * 请问，下面那个排序更适合    直接插入排序。
     * 另外：直接插入排序一般也会用在一些排序的优化上。
     * 快速排序。
     * 空间复杂度：
     * 稳定性：稳定的排序
     */
    
    public static void insertSort(int[] array) {
        for (int i = 1; i < array.length; i++) {
            int tmp = array[i];
            int j = i - 1;
            for (; j >= 0; j--) {
                //如果这里是一个大于等于号 此时这个排序就不稳定了
                if (array[j] > tmp) {
                    array[j + 1] = array[j];
                } else {
                    //array[j+1] = tmp;
                    break;
                }
            }
            array[j + 1] = tmp;
        }
    }
}
